# 数字逻辑设计

高翠芸 School of Computer Science gaocuiyun@hit.edu.cn











#### Moore's Law: The number of transistors on microchips doubles every two years Our World

Our World in Data

Moore's law describes the empirical regularity that the number of transistors on integrated circuits doubles approximately every two years. This advancement is important for other aspects of technological progress in computing – such as processing speed or the price of computers.



Data source: Wikipedia (wikipedia.org/wiki/Transistor count)

Year in which the microchip was first introduced

OurWorldinData.org - Research and data to make progress against the world's largest problems.

Licensed under CC-BY by the authors Hannah Ritchie and Max Roser.



英伟达3个月卖出800吨H100! 云服务供应商的大规模H100 集群容量即将耗尽,全球陷入GPU短缺——整体算来,全球公司需要约432000张H100。

by 新智元

#### WHEN EVERYONE DIGS FOR GOLD



## 集成电路的分类

| 分类             | 单芯片内集成的逻<br>辑门数量 | 集成内容 | 器件封装 | 需要掌握的内容 |
|----------------|------------------|------|------|---------|
| 小规模<br>(SSI)   |                  |      |      |         |
| 中规模<br>(MSI)   |                  |      |      |         |
| 大规模<br>(LSI)   |                  |      |      | -       |
| 超大规模<br>(VLSI) |                  |      |      |         |

## 加减法器和0C门

- ■半加器
- ■全加器
- ■多位加法器
- ■全减器
- OCi门

### 半加器(Half Adder)

#### 功能:对两个1位二进制数执行相加运算



$$S_i = a_i \oplus b_i$$

$$C_{i+1} = a_i b_i$$

$$C_{i+1} = a_i b_i$$

#### 真值表

| a <sub>i</sub> b <sub>i</sub> | S <sub>i</sub> C <sub>i+1</sub> |
|-------------------------------|---------------------------------|
| 0 0                           | 0 0                             |
| 0 1                           | 1 0                             |
| 1 0                           | 1 0                             |
| 1 1                           | 0 1                             |



### 利用单一逻辑门与非门实现半加器

$$\begin{cases} S_{i} = \overline{a}_{i}b_{i} + a_{i}\overline{b}_{i} = \overline{a}_{i}b_{i} + a_{i}\overline{b}_{i} + a_{i}\overline{a}_{i} + b_{i}\overline{b}_{i} \\ = a_{i}(\overline{a}_{i} + \overline{b}_{i}) + b_{i}(\overline{a}_{i} + \overline{b}_{i}) = a_{i}\overline{a}_{i}\overline{b}_{i} + b_{i}\overline{a}_{i}\overline{b}_{i} \\ = \overline{a_{i}}\overline{a_{i}}\overline{b_{i}}\overline{b_{i}}\overline{a_{i}}\overline{b_{i}} \\ C_{i+1} = \overline{a_{i}}\overline{b_{i}} \end{cases}$$



### 全加器(Full Adder)

1 0 1 1 ...... A

1 1 1 0 ...... B

$$C_i$$

A =  $a_3 a_2 a_1 a_0 = 1011$ 
 $C_i$ 

B =  $b_3 b_2 b_1 b_0 = 1110$ 

### 全加器表示



| $\mathbf{a_i}$ | b <sub>i</sub> ( | $C_{\mathbf{i}}$ | $S_i C_{i+1}$ | L |
|----------------|------------------|------------------|---------------|---|
| 0              | 0                | 0                | 0 0           |   |
| 0              | 0                | 1                | 1 0           |   |
| 0              | 1                | 0                | 1 0           |   |
| 0              | 1                | 1                | 0 1           |   |
| 1              | 0                | 0                | 1 0           |   |
| 1              | 0                | 1                | 0 1           |   |
| 1              | 1                | 0                | 0 1           |   |
| 1              | 1                | 1                | 1 1           |   |

| $a_i$ 00 01 11 10 $a_i$ 00 01 11 10                   | $\mathbf{b_{i}c}$ | <b></b> i+1 |    |
|-------------------------------------------------------|-------------------|-------------|----|
|                                                       | _                 | 01 11 10    | .0 |
|                                                       | 0                 | 0 1         | 0  |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | 1                 | (1   1)     | 1  |

$$S_{i} = \overline{a}_{i}\overline{b}_{i}c_{i} + a_{i}\overline{b}_{i}\overline{c}_{i} + a_{i}\overline{b}_{i}\overline{c}_{i} + a_{i}\overline{b}_{i}c_{i} + a_{i}\overline{b}_{i}c_{i}$$

$$= (\overline{a}_{i}\overline{b}_{i} + a_{i}\overline{b}_{i}) c_{i} + (a_{i}\overline{b}_{i} + a_{i}\overline{b}_{i}) \overline{c}_{i}$$

$$= (\overline{a}_{i} \oplus \overline{b}_{i}) c_{i} + (a_{i} \oplus \overline{b}_{i}) \overline{c}_{i}$$

$$= a_{i} \oplus \overline{b}_{i} \oplus \overline{C}_{i}$$

$$C_{i+1} = (a_i \oplus b_i) C_i + a_i b_i$$

### 全加器逻辑表示

solution 1:

$$\begin{cases} S_i = a_i \oplus b_i \oplus C_i \\ C_{i+1} = (a_i \oplus b_i) C_i + a_i b_i \end{cases}$$





### 全加器逻辑表示(2)

#### solution 2



$$\begin{split} S_i &= a_i \ \oplus \ b_i \ \oplus \ C_i \\ C_{i+1} &= (a_i \ \oplus \ b_i \ ) \ C_i + a_i b_i \\ & \qquad \qquad \\ \begin{cases} S_i &= a_i \ \oplus \ b_i \\ C_{i+1} &= a_i b_i \\ \end{cases} \end{split}$$

### 全加器的应用

#### 典型芯片

**74LS82:** 2-bit adder

**74LS283:** 4-bit adder

| 二进制数<br>A <sub>3</sub> A <sub>2</sub> A <sub>1</sub> A <sub>0</sub> | 余三码<br>S <sub>3</sub> S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> | 二进制数<br>A <sub>3</sub> A <sub>2</sub> A <sub>1</sub> A <sub>0</sub> | 余三码<br>S <sub>3</sub> S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> |
|---------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------|
| 0 0 0 0                                                             | 0 0 1 1                                                            | 1000                                                                | 1 0 1 1                                                            |
| 0 0 0 1                                                             | 0 1 0 0                                                            | 1001                                                                | 1 1 0 0                                                            |
| 0 0 1 0                                                             | 0 1 0 1                                                            | 1010                                                                | X                                                                  |
| 0 0 1 1                                                             | 0 1 1 0                                                            | 1011                                                                | ×                                                                  |
| 0 1 0 0                                                             | 0111                                                               | 1 1 0 0                                                             | X                                                                  |
| 0 1 0 1                                                             | 1000                                                               | 1 1 0 1                                                             | X                                                                  |
| 0 1 1 0                                                             | 1001                                                               | 1110                                                                | ×                                                                  |
| 0 1 1 1                                                             | 1010                                                               | 1111                                                                | ×                                                                  |

#### 应用——余3码产生器



A<sub>3</sub>A<sub>2</sub>A<sub>1</sub>A<sub>0</sub>: 输入 8421 BCD码

S<sub>3</sub>S<sub>2</sub>S<sub>1</sub>S<sub>0</sub>: 输出余3 码

S = A + 0011

#### (1) 串行进位



 $A = A_3 A_2 A_1 A_0 = 1011$  $B = B_3 B_2 B_1 B_0 = 1110$ 

 $S_i = a_i \oplus b_i \oplus C_i$   $C_{i+1} = (a_i \oplus b_i) C_i + a_i b_i$ 

- 缺点:串行进位,运算速度慢
- · 优点:线路简单
- 关键:进位形成时间
- 解决方案: 改串行进位为并行进位

#### (2) 超前进位



$$C_{i+1} = (A_i \oplus B_i) C_i + A_i B_i$$

$$A = A_3 A_2 A_1 A_0 = 1011$$
  
 $B = B_3 B_2 B_1 B_0 = 1110$ 

$$C_{i+1}=P_iC_i+G_i$$
  
 $P_i=A_i\oplus B_i$   
 $G_i=A_iB_i$ 
——进位迭代公式

$$G_i = A_i B_i$$

$$C_{1} = P_{0}C_{0} + G_{0}$$

$$C_{2} = P_{1}C_{1} + G_{1} = P_{1}P_{0}C_{0} + P_{1}G_{0} + G_{1}$$

$$C_{3} = P_{2}C_{2} + G_{2} = P_{2}P_{1}P_{0}C_{0} + P_{2}P_{1}G_{0} + P_{2}G_{1} + G_{2}$$

$$C_{4} = P_{3}C_{3} + G_{3} = P_{3}P_{2}P_{1}P_{0}C_{0} + P_{3}P_{2}P_{1}G_{0} + P_{3}P_{2}G_{1} + P_{3}G_{2} + G_{3}$$

### (2) 超前进位





$$P_{i} = A_{i} \oplus B_{i} \qquad G_{i} = A_{i}B_{i}$$

$$C_{1} = P_{0}C_{0} + G_{0}$$

$$C_{2} = P_{1}C_{1} + G_{1} = P_{1}P_{0}C_{0} + P_{1}G_{0} + G_{1}$$

$$C_{3} = P_{2}C_{2} + G_{2} = P_{2}P_{1}P_{0}C_{0} + P_{2}P_{1}G_{0} + P_{2}G_{1} + G_{2}$$

$$C_{4} = P_{3}C_{3} + G_{3} = P_{3}P_{2}P_{1}P_{0}C_{0} + P_{3}P_{2}P_{1}G_{0} + P_{3}P_{2}G_{1} + P_{3}G_{2} + G_{3}$$

## 全减器 (Binary Full Subtracter)





$$A = a_3 a_2 a_1 a_0 = 1110$$
  
 $B = b_3 b_2 b_1 b_0 = 1011$ 

#### 真值表

| a <sub>i</sub> | b <sub>i</sub> | C <sub>i</sub> | D <sub>i</sub> | C <sub>i+1</sub> |
|----------------|----------------|----------------|----------------|------------------|
| 0              | 0              | 0              | 0              | 0                |
| 0              | 0              | 1              | 1              | 1                |
| 0              | 1              | 0              | 1              | 1                |
| 0              | 1              | 1              | 0              | 1                |
| 1              | 0              | 0              | 1              | 0                |
| 1              | 0              | 1              | 0              | 0                |
| 1              | 1              | 0              | 0              | 0                |
| 1              | 1              | 1              | 1              | 1                |

### 全减器——例

真值表

| a <sub>i</sub> | b <sub>i</sub> | C <sub>i</sub> | D <sub>i</sub> | C <sub>i+1</sub> |
|----------------|----------------|----------------|----------------|------------------|
| 0              | 0              | 0              | 0              | 0                |
| 0              | 0              | 1              | 1              | 1                |
| 0              | 1              | 0              | 1              | 1                |
| 0              | 1              | 1              | 0              | 1                |
| 1              | 0              | 0              | 1              | 0                |
| 1              | 0              | 1              | 0              | 0                |
| 1              | 1              | 0              | 0              | 0                |
| 1              | 1              | 1              | 1              | 1                |

$$\begin{cases} \mathbf{D_i} = \mathbf{a_i} \oplus \mathbf{b_i} \oplus \mathbf{C_i} \\ \mathbf{C_{i+1}} = (\mathbf{C_i} \oplus \mathbf{b_i}) \mathbf{a_i} + \mathbf{C_i} \mathbf{b_i} \end{cases}$$





## OC门(集电极开路门: Open Collector Gate)



- ■几个OC门的输出端可以直接互连: ●使用时必须加负载/上拉电阻

## OC门&线与

$$F=F_1 \cdot F_2 = \overline{A_1B_1C_1} \cdot \overline{A_2B_2C_2}$$

不使用OC门, 需要2个与非 门、1个与门



## 小 结

- ■半加器
- ■全加器
- ■多位加法器
- ■全减器
- OCi つ

## Unit 7 组合逻辑元件

- 多路复用器(multiplexers)
- 三态器件(Three-state Buffer)
- 译码器(Decoders)
- 编码器(Encoders)
- ■奇偶校验器
- ■比较器
- 只读存储器(ROM)
- ■利用MSI设计组合逻辑电路

## Unit 7 组合逻辑元件

- <u>多路复用器(multiplexers)</u>
- 三态器件(Three-state Buffer)
- 译码器(Decoders)
- 编码器(Encoders)
- ■奇偶校验器
- ■比较器
- 只读存储器(ROM)
- ■利用MSI设计组合逻辑电路

## 数据选择器/多路开关



#### 2选1数据选择器



控制端最小项 $m_k$ 的 字号K,指向了第K路数据输入端 $I_k$ 。

 $m_k$  —— n 个控制变量的最小项  $I_k$  ——第 k 路数据输入

#### 数据选择器的功能:

- ① 从多路输入中选择一个送往输出端(2n选1);
- ② 选择哪一路输入送到输出端由控制信号决定;

用途: 实现多通道的数据传送;

## 4选1数据选择器



$$F = \overline{E}_n(D_0 \overline{A}_1 \overline{A}_0 + D_1 \overline{A}_1 A_0 + D_2 \overline{A}_1 \overline{A}_0 + D_3 \overline{A}_1 A_0)$$

| E <sub>n</sub> | $\mathbf{A_1}$ | $\mathbf{A_0}$ | F              |
|----------------|----------------|----------------|----------------|
| 1              | ×              | ×              | 0              |
| 0              | 0              | 0              | $\mathbf{D}_0$ |
| 0              | 0              | 1              | $\mathbf{D}_1$ |
| 0              | 1              | 0              | $\mathbf{D}_2$ |
| 0              | 1              | 1              | $\mathbf{D}_3$ |

功能表

#### ■ 典型应用——实现常规逻辑函数



$$Z = \overline{C}\overline{D}(\overline{A} + \overline{B}) + \overline{C}D\overline{A} + C\overline{D}(\overline{A}\overline{B} + \overline{A}\overline{B}) + CD(0)$$

$$= \overline{A}\overline{C} + \overline{A}\overline{B}\overline{D} + \overline{A}\overline{D}B \odot C$$

### 8选1数据选择器



#### 单一逻辑门实现





#### 数据选择器级 联实现





$$Z = A'B'C'I_0 + A'B'CI_1 + A'BC'I_2 + A'BCI_3 + AB'C'I_4 + AB'CI_5 + ABC'I_6 + ABCI_7$$

## 双4选1典型器件74LS153

| 1Gn | 2Gn | A | В | 1Y 2Y                           |
|-----|-----|---|---|---------------------------------|
| 1   | 1   | × | × | 0 0                             |
| 0   | 0   | 0 | 0 | 1C <sub>0</sub> 2C <sub>0</sub> |
| 0   | 0   | 0 | 1 | 1C <sub>1</sub> 2C <sub>1</sub> |
| 0   | 0   | 1 | 0 | 1C <sub>2</sub> 2C <sub>2</sub> |
| 0   | 0   | 1 | 1 | 1C <sub>3</sub> 2C <sub>3</sub> |







#### 使能端

使能端是**控制信号输入端**,又叫**使能输入端**(enable),它是芯片的一个输入引脚,或者电路的一个输入端口,只有该引脚激活,芯片才能工作,若符号上面有一横/带有非号,则表示**低电平有效**,否则为**高电平有效**。



## Unit 7 组合逻辑元件

- 多路复用器(multiplexers)
- 三态器件(Three-state Buffer)
- 译码器(Decoders)
- 编码器(Encoders)
- ■奇偶校验器
- ■比较器
- 只读存储器(ROM)
- ■利用MSI设计组合逻辑电路

## 三态门(Three-State Buffers)

#### 三态——

- **0**
- **1**
- Z: 高阻态

- 包括三态恒等门、三态非门、三态与非门等, 缓冲器(驱动门)。
- 用途之一: 可用来增强输出驱动能力



#### 三态门(恒等)

B: 使能端, 高电平有效

#### 真值表

| В | Α | С |
|---|---|---|
| 0 | 0 | Z |
| 0 | 1 | Z |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

### 三态门(Three-State Buffers)



| В | Α | C                | В | Α | C | В | Α | C | В | Α | C |
|---|---|------------------|---|---|---|---|---|---|---|---|---|
| 0 | 0 | Z<br>Z<br>0<br>1 | 0 | 0 | Z | 0 | 0 | 0 | 0 | 0 | 1 |
| 0 | 1 | Z                | 0 | 1 | Z | 0 | 1 | 1 | 0 | 1 | 0 |
| 1 | 0 | 0                | 1 | 0 | 1 | 1 | 0 | Z | 1 | 0 | Z |
| 1 | 1 | 1                | 1 | 1 | 0 | 1 | 1 | Z | 1 | 1 | Z |
|   |   | •                |   |   |   |   |   |   |   |   |   |

高阻态: 电阻很大, 相当于开路

高阻态相当于该门同与它连接的电路处于断开的状态。(实际电路中不可能去断开它)

## 三态门





|                       |   | <i>S</i> <sub>2</sub> |   |   |
|-----------------------|---|-----------------------|---|---|
| <i>S</i> <sub>1</sub> | X | 0                     | 1 | Z |
| X                     | X | Χ                     | X | X |
| 0                     | X | 0                     | X | 0 |
| 1                     | X | X                     | 1 | 1 |
| Z                     | X | 0                     | 1 | Z |

## 三态门



- 三态器件允许多个信号源 共享单个"总线"(同线), 但线上每次仅一个器件 "谈话"。
- 假如不是全部EN线有效, 则没有一个三态缓冲器能 被使能,此时SDATA上的逻辑值是"未定义",悬空 信号的实际电压值依赖于 电路细节。
- · 对典型的三态器件,进入高阻态比离开高阻态快,减少系统中产生的冲突(fighting)。

## 三态门



使用三态器件唯一真正 安全的方法是设计逻辑 控制,以保证同线上有 一段截止时间(dead time),在此期间不应 有任何器件驱动同线。

## 三态门应用





## 三态门应用——续

■ 双向数据总线 Data Bus Memory **DSP** CPU I/O unit "1" I/O control Data out Data in Data in Data out Bi-direction databus I/O control "1" **Device A** Device B

#### 三态门应用——续

#### 内存里的一个存储单元

- •读写控制线处于低电位时,可以写入;
- •读写控制线处于高电位时,可以读出;
- 但是不读不写,就要用高阻态。

# 三态门的应用

 $X=X_3X_2X_1X_0$ 为8421BCD码,设计一个MOD 5选择电路,要求选择那些能被5整除的数输出。 ①真值表(F为控制信号)



| $X_3 X_2 X_1 X_0$ | F | $X_3 X_2 X_1 X_0$ | F |
|-------------------|---|-------------------|---|
| 0 0 0 0           | 1 | 1 0 0 0           | 0 |
| 0 0 0 1           | 0 | 1 0 0 1           | 0 |
| 0 0 1 0           | 0 | 1 0 1 0           | × |
| 0 0 1 1           | 0 | 1 0 1 1           | × |
| 0 1 0 0           | 0 | 1 1 0 0           | × |
| 0 1 0 1           | 1 | 1 1 0 1           | × |
| 0 1 1 0           | 0 | 1 1 1 0           | × |
| 0 1 1 1           | 0 | 1 1 1 1           | X |

# 三态门的应用——续

#### ② 化简



$$F = \overline{X_{2}\overline{X}_{1}X_{0} + \overline{X}_{3}\overline{X}_{2}\overline{X}_{1}\overline{X}_{0}}$$

$$= (\overline{X_{2}\overline{X}_{1}X_{0}}) (\overline{\overline{X}_{3}\overline{X}_{2}\overline{X}_{1}\overline{X}_{0}})$$

$$\overline{\mathbf{F}} = (\overline{\mathbf{X}_2 \overline{\mathbf{X}}_1 \mathbf{X}_0}) \ (\overline{\overline{\mathbf{X}}_3 \overline{\mathbf{X}}_2 \overline{\mathbf{X}}_1 \overline{\mathbf{X}}_0})$$

#### ③ 逻辑图



#### Unit 7 组合逻辑元件

- 多路复用器(multiplexers)
- 三态器件(Three-state Buffer)
- <u>译码器(Decoders)</u>
- 编码器(Encoders)
- ■奇偶校验器
- ■比较器
- 只读存储器(ROM)
- ■利用MSI设计组合逻辑电路

## 译码器及分类

◆ 特点:多输入、多输出的组合逻辑电路

◆ 功能:将一种编码转换为另一种编码

| 分类      | 特点                                                                                                                 | 译码演示                                                                                                                                                          |
|---------|--------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 二进制译码器  | <ul> <li>n 位二进制码</li> <li>N位(N=2"),每根输出线都与一个输入最小项唯一对应(输出线编号值=最小项编号值)</li> <li>每个最小项输入,只能使 N 根输出线中的一个输出有效</li></ul> | 0<br>C<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P                                                              |
| 代码转换译码器 | 从一种编码转换为另一种编码<br>(例如:8421BCD码→余3码)                                                                                 | $ \begin{array}{ccc} A \longrightarrow & & & X_1 \\ B \longrightarrow & & & X_2 \\ X \longrightarrow & & & X_3 \\ D \longrightarrow & & & & X_4 \end{array} $ |
| 显示译码器   | 将输入的编码信号转换为十进制码或其它特定<br>编码,用来驱动显示器件显示相应的文字符号。                                                                      | Seven-Segment Indicator $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                |

# 二进制译码器举例——3线-8线译码器



| 衐              | 吏能站      | 岩 |   | 输入 |   | 译码输出  |                  |       |                |                | +              |       |                       |  |  |
|----------------|----------|---|---|----|---|-------|------------------|-------|----------------|----------------|----------------|-------|-----------------------|--|--|
| G <sub>1</sub> | $G_{2A}$ |   | С | В  | Α | $Y_0$ | $\mathbf{Y}_{1}$ | $Y_2$ | Y <sub>3</sub> | Y <sub>4</sub> | Y <sub>5</sub> | $Y_6$ | <b>Y</b> <sub>7</sub> |  |  |
| 0              | X        | X | X | X  | X | 1     | 1                | 1     | 1              | 1              | 1              | 1     | 1                     |  |  |
| X              | 1        | X | X | X  | X | 1     | 1                | 1     | 1              | 1              | 1              | 1     | 1                     |  |  |
| X              | X        | 1 | X | X  | X | 1     | 1                | 1     | 1              | 1              | 1              | 1     | 1                     |  |  |
| 1              | 0        | 0 | 0 | 0  | 0 | 0     | 1                | 1     | 1              | 1              | 1              | 1     | 1                     |  |  |
| 1              | 0        | 0 | 0 | 0  | 1 | 1     | 0                | 1     | 1              | 1              | 1              | 1     | 1                     |  |  |
| 1              | 0        | 0 | 0 | 1  | 0 | 1     | 1                | 0     | 1              | 1              | 1              | 1     | 1                     |  |  |
| 1              | 0        | 0 | 0 | 1  | 1 | 1     | 1                | 1     | 0              | 1              | 1              | 1     | 1                     |  |  |
| 1              | 0        | 0 | 1 | 0  | 0 | 1     | 1                | 1     | 1              | 0              | 1              | 1     | 1                     |  |  |
| 1              | 0        | 0 | 1 | 0  | 1 | 1     | 1                | 1     | 1              | 1              | 0              | 1     | 1                     |  |  |
| 1              | 0        | 0 | 1 | 1  | 0 | 1     | 1                | 1     | 1              | 1              | 1              | 0     | 1                     |  |  |
| 1              | 0        | 0 | 1 | 1  | 1 | 1     | 1                | 1     | 1              | 1              | 1              | 1     | 0                     |  |  |

\ 译码器输出: 低电平有效

$$y_i = \overline{m}_i = M_i$$

# 3线-8线译码器

译码器输出:高电平有效 🛶  $y_i = m_i$ 



| ĺ              | 吏能              | 端               | 3 | 输入 | • | 译码输出           |                |                |                |       |                       |                |                       |
|----------------|-----------------|-----------------|---|----|---|----------------|----------------|----------------|----------------|-------|-----------------------|----------------|-----------------------|
| G <sub>1</sub> | G <sub>2A</sub> | G <sub>2B</sub> | С | В  | Α | Y <sub>0</sub> | Y <sub>1</sub> | Y <sub>2</sub> | Y <sub>3</sub> | $Y_4$ | <b>Y</b> <sub>5</sub> | Y <sub>6</sub> | <b>Y</b> <sub>7</sub> |
| 0              | X               | X               | X | X  | X | 0              | 0              | 0              | 0              | 0     | 0                     | 0              | 0                     |
| X              | 1               | X               | X | X  | X | 0              | 0              | 0              | 0              | 0     | 0                     | 0              | 0                     |
| X              | X               | 1               | X | X  | X | 0              | 0              | 0              | 0              | 0     | 0                     | 0              | 0                     |
| 1              | 0               | 0               | 0 | 0  | 0 | 1              | 0              | 0              | 0              | 0     | 0                     | 0              | 0                     |
| 1              | 0               | 0               | 0 | 0  | 1 | 0              | 1              | 0              | 0              | 0     | 0                     | 0              | 0                     |
| 1              | 0               | 0               | 0 | 1  | 0 | 0              | 0              | 1              | 0              | 0     | 0                     | 0              | 0                     |
| 1              | 0               | 0               | 0 | 1  | 1 | 0              | 0              | 0              | 1              | 0     | 0                     | 0              | 0                     |
| 1              | 0               | 0               | 1 | 0  | 0 | 0              | 0              | 0              | 0              | 1     | 0                     | 0              | 0                     |
| 1              | 0               | 0               | 1 | 0  | 1 | 0              | 0              | 0              | 0              | 0     | 1                     | 0              | 0                     |
| 1              | 0               | 0               | 1 | 1  | 0 | 0              | 0              | 0              | 0              | 0     | 0                     | 1              | 0                     |
| 1              | 0               | 0               | 1 | 1  | 1 | 0              | 0              | 0              | 0              | 0     | 0                     | 0              | 1                     |

## 二进制译码器的典型应用——地址译码

- 微处理器的地址译码
  - \*假设A0—A7连接到各个外设的低8位地址线。



# 地址译码

•图示电路的整个地址译码范围?各个外设的地址译码范围?





- 1 整个地址译码范围为: [填空1]H— [填空2]H
- 2 外设1的地址译码范围为: [填空3] H--[填空4] H
- 3 外设2的地址译码范围为: [填空5] H—[填空6] H



作答

## 地址译码例题

#### ■ 地址译码

图示电路的整个地址译码范围?

各个外设的地址译码范围?

#### 整个译码器的地址译码范围:





最小取值 1000H

最大取值 1FFFH

#### 外设1的地址译码范围:

| $A_1$ | <b>A</b> <sub>1</sub> | A <sub>1</sub> | A <sub>1</sub> | A <sub>1</sub> | <b>A</b> <sub>1</sub> | A <sub>9</sub> | A <sub>8</sub> | A <sub>7</sub> | A <sub>6</sub> | <b>A</b> <sub>5</sub> | A <sub>4</sub> | <b>A</b> <sub>3</sub> | A <sub>2</sub> | $A_1$ | $A_0$ |
|-------|-----------------------|----------------|----------------|----------------|-----------------------|----------------|----------------|----------------|----------------|-----------------------|----------------|-----------------------|----------------|-------|-------|
| 0     | 0                     | 3<br><b>0</b>  | 1              | 0              | 1                     | 0              | Ñ              | Ñ              | A              | Ñ                     | A              | Ñ                     | Ñ              | A     | Ñ     |
| :     | :                     | :              | ÷              | ÷              | :                     | :              | :              | :              | ÷              | :                     | ÷              | i                     | ÷              | :     | ÷     |
| 0     | 0                     | 0              | 1              | 0              | 1                     | 0              | 1              | 1              | 1              | 1                     | 1              | 1                     | 1              | 1     | 1     |
|       |                       | ,              | -              | •              | -                     |                | •              | •              | •              | •                     | •              | •                     | •              | •     | •     |

最小取值 1400H

最大取值 15FFH

## 二进制译码器的典型应用——译码器级联

• 3线-8线译码器扩展为4线-16线译码

**(I)** 



|   | 输        | λ |   | 译码输出           |                  |                  |                |       |         |                |                |  |
|---|----------|---|---|----------------|------------------|------------------|----------------|-------|---------|----------------|----------------|--|
| D | <b>C</b> | В | A | $\mathbf{Y_0}$ | $\mathbf{Y}_{1}$ | $\mathbf{Y}_{2}$ | $\mathbf{Y_3}$ | $Y_4$ | $ Y_5 $ | $\mathbf{Y_6}$ | $\mathbf{Y}_7$ |  |
| 0 | 0        | 0 | 0 | 0              | 1                | 1                | 1              | 1     | 1       | 1              | 1              |  |
| 0 | 0        | 0 | 1 | 1              | 0                | 1                | 1              | 1     | 1       | 1              | 1              |  |
| 0 | 0        | 1 | 0 | 1              | 1                | 0                | 1              | 1     | 1       | 1              | 1              |  |
| 0 | 0        | 1 | 1 | 1              | 1                | 1                | 0              | 1     | 1       | 1              | 1              |  |
| 0 | 1        | 0 | 0 | 1              | 1                | 1                | 1              | 0     | 1       | 1              | 1              |  |
| 0 | 1        | 0 | 1 | 1              | 1                | 1                | 1              | 1     | 0       | 1              | 1              |  |
| 0 | 1        | 1 | 0 | 1              | 1                | 1                | 1              | 1     | 1       | 0              | 1              |  |
| 0 | 1        | 1 | 1 | 1              | 1                | 1                | 1              | 1     | 1       | 1              | 0              |  |

(II)

|   | 输 | 入 |   |                | 译码输出           |                  |                |                |                    |                  |                |
|---|---|---|---|----------------|----------------|------------------|----------------|----------------|--------------------|------------------|----------------|
| D | C | B | A | $\mathbf{Y_0}$ | $\mathbf{Y_1}$ | $\mathbf{Y}_{2}$ | $\mathbf{Y_3}$ | $\mathbf{Y_4}$ | $ \mathbf{Y}_{5} $ | $\mathbf{Y}_{6}$ | $\mathbf{Y}_7$ |
| 1 | 0 | 0 | 0 | 0              | 1              | 1                | 1              | 1              | 1                  | 1                | 1              |
| 1 | 0 | 0 | 1 | 1              | 0              | 1                | 1              | 1              | 1                  | 1                | 1              |
| 1 | 0 | 1 | 0 | 1              | 1              | 0                | 1              | 1              | 1                  | 1                | 1              |
| 1 | 0 | 1 | 1 | 1              | 1              | 1                | 0              | 1              | 1                  | 1                | 1              |
| 1 | 1 | 0 | 0 | 1              | 1              | 1                | 1              | 0              | 1                  | 1                | 1              |
| 1 | 1 | 0 | 1 | 1              | 1              | 1                | 1              | 1              | 0                  | 1                | 1              |
| 1 | 1 | 1 | 0 | 1              | 1              | 1                | 1              | 1              | 1                  | 0                | 1              |
| 1 | 1 | 1 | 1 | 1              | 1              | 1                | 1              | 1              | 1                  | 1                | 0              |

#### 编码转换译码器

- •例:设计一个译码器,
- 将输入的4位二进制数转换为典型格雷码







|      | 4                   |
|------|---------------------|
| X= A | $\oplus \textbf{B}$ |
| Y= B | $\oplus \mathbf{C}$ |
| LZ=C | $\oplus \mathbf{D}$ |







| ABCD | WXYZ | ABCD | WXYZ |
|------|------|------|------|
| 0000 | 0000 | 1000 | 1100 |
| 0001 | 0001 | 1001 | 1101 |
| 0010 | 0011 | 1010 | 1111 |
| 0011 | 0010 | 1011 | 1110 |
| 0100 | 0110 | 1100 | 1010 |
| 0101 | 0111 | 1101 | 1011 |
| 0110 | 0101 | 1110 | 1001 |
| 0111 | 0100 | 1111 | 1000 |

#### 七段显示译码器

显示译码器:与显示器件(如数码管)配合,将输入代码转换为十进制码或特定编码,并在显示器件上显示相应的字形



8421BCD码驱动的共阴极七段 数码管显示译码器功能表

|   | 输 | λ |   |   | 译码输出 |   |   |   |   |            |  |  |
|---|---|---|---|---|------|---|---|---|---|------------|--|--|
| A | В | C | D | a | b    | С | d | е | f | g          |  |  |
| 0 | 0 | 0 | 0 | 1 | 1    | 1 | 1 | 1 | 1 | 0          |  |  |
| 0 | 0 | 0 | 1 | 0 | 1    | 1 | 0 | 0 | 0 | 0          |  |  |
| 0 | 0 | 1 | 0 | 1 | 1    | 0 | 1 | 1 | 0 | 1          |  |  |
| 0 | 0 | 1 | 1 | 1 | 1    | 1 | 1 | 0 | 0 | 1          |  |  |
| 0 | 1 | 0 | 0 | 0 | 1    | 1 | 0 | 0 | 1 | 1          |  |  |
| 0 | 1 | 0 | 1 | 1 | 0    | 1 | 1 | 0 | 1 | 1          |  |  |
| 0 | 1 | 1 | 0 | 1 | 0    | 1 | 1 | 1 | 1 | 1          |  |  |
| 0 | 1 | 1 | 1 | 1 | 1    | 1 | 0 | 0 | 0 | 0          |  |  |
| 1 | 0 | 0 | 0 | 1 | 1    | 1 | 1 | 1 | 1 | 1          |  |  |
| 1 | 0 | 0 | 1 | 1 | 1    | 1 | 1 | 0 | 1 | 5 <b>q</b> |  |  |



#### Unit 7 组合逻辑元件

- 多路复用器(multiplexers)
- 三态器件(Three-state Buffer)
- 译码器(Decoders)
- 编码器(Encoders)
- ■奇偶校验器
- ■比较器
- 只读存储器(ROM)
- ■利用MSI设计组合逻辑电路

# 编码器

◆ 特点:多输入、多输出的组合逻辑电路

◆ 功能:将二进制码按照一定规律编排,使其具有特定含义,与译码器互逆。

| 常用编码器                 | 特点                                                              | 编码演示                                                                                                                             |
|-----------------------|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 普通编码器<br>(二进制编码<br>器) | N位,任何时刻N 根输入线中只能有一个输入有效,N(N=2")中取一。         n 位二进制码             | □ Y <sub>0</sub> C 0                                                                                                             |
| 优先编码器                 | 允许同时输入两个以上的有效编码输入信号,<br>优先编码器能按照预先设定的优先级别,只<br>对其中优先级最高的输入进行编码。 | □ Y <sub>0</sub> C 0 1 Y <sub>1</sub> C 1 Y <sub>2</sub> B 1 Y <sub>5</sub> A 1 Y <sub>6</sub> Y <sub>7</sub> C 1 (8 线-3 线优先编码器) |

# 键盘编码器



#### 键盘编码器功能表

| P <sub>9</sub> P <sub>1</sub> | 按键 | WXYZ |
|-------------------------------|----|------|
| 111111111                     | 0  | 0000 |
| 11111111 <mark>0</mark>       | 1  | 0001 |
| 1111111 <mark>0</mark> 1      | 2  | 0010 |
| 111111 <mark>0</mark> 11      | 3  | 0011 |
| 11111 <mark>0</mark> 111      | 4  | 0100 |
| 1111 <mark>0</mark> 1111      | 5  | 0101 |
| 111011111                     | 6  | 0110 |
| 11 <mark>0</mark> 111111      | 7  | 0111 |
| 1 <mark>0</mark> 1111111      | 8  | 1000 |
| <b>0</b> 11111111             | 9  | 1001 |







| - | 0 | 10 | 0000 | 8 | 18  | 1000 |
|---|---|----|------|---|-----|------|
| - | 1 | 11 | 0001 | 9 | 19  | 1001 |
| - | 2 | 12 | 0010 | 1 | 110 | 1010 |
| - | 3 | 13 | 0011 | * | 111 | 1011 |
| - | 4 | 14 | 0100 | - | 112 | 1100 |
| ١ | 5 | 15 | 0101 | + | 113 | 1101 |
| 1 | 6 | 16 | 0110 |   | 114 | 1110 |
| ١ | 7 | 17 | 0111 | = | 115 | 1111 |
|   |   |    |      |   |     |      |

$$W=(P_8 \cdot P_9)'$$
  
 $Y=(P_2 \cdot P_3 \cdot P_6 \cdot P_7)'$ 

$$X = (P_4 \cdot P_5 \cdot P_6 \cdot P_7)'$$
  
 $Z = (P_1 \cdot P_3 \cdot P_5 \cdot P_7 \cdot P_9)'$ 

# 键盘编码器

#### 4:2编码器

计算机配有四个外部设备: 声卡(A0), 硬盘驱动器 (A1), 鼠标(A2), 网卡(A3), B<sub>0</sub>、B<sub>1</sub>为编码输出。



#### 抢答器输出



| A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | $A_0$ | B <sub>1</sub> | B <sub>0</sub> |
|----------------|----------------|----------------|-------|----------------|----------------|
| 0              | 0              | 0              | 1     | 0              | 0              |
| 0              | 0              | 1              | 0     | 0              | 1              |
| 0              | 1              | 0              | 0     | 1              | 0              |
| 1              | 0              | 0              | 0     | 1              | 1              |

某一时刻只允许输入一个编码信号,如 $A_1$ ( $A_1$ =1) 向 CPU 请求传送数据,CPU 根据接收的编码  $B_1B_0$  = 01,启动硬盘驱动器,开始传送数据。

普通编码器:无法避免错误输入(同时 输入多路有效信号)、容易造成混乱。

# 4:2优先编码器



| $A_3$ | A <sub>2</sub> | $\mathbf{A_1}$ | $\mathbf{A_0}$ | <b>B</b> <sub>1</sub> | $\mathbf{B}_{0}$ |
|-------|----------------|----------------|----------------|-----------------------|------------------|
| 0     | 0              | 0              | 1              | 0                     | 0                |
| 0     | 0              | 1              | X              | 0                     | 1                |
| 0     | 1              | X              | X              | 1                     | 0                |
| 1     | X              | X              | X              | 1                     | 1                |

$$A = A0 \overline{A1} \overline{A2} \overline{A3}$$

$$\mathbf{B} = \mathbf{A}1 \overline{\mathbf{A}2} \overline{\mathbf{A}3}$$

$$C = A2 \overline{A3}$$

$$D = A3$$

#### 二进制编码器:

- 可以对2<sup>n</sup>个输入对象编码
- 只需n个输出端(每个对象获得一个n位编码)
- 编码具有唯一性

#### 优先编码器:

- 允许同时输入多路有效信号
- 按照预先设定的优先级,只对其中优先级最高的输 入进行编码。

#### 编码器典型芯片74LS148

#### 标志位:

0:编码输出;1:非编码输出



输入和输出均为低电平被有效。

#### 输入使能

#### 8线-3线优先编码器

输出使能

|                         |             | 输           |             |           | )           | \           |             |             | :                | 输                |                  | 出                         |                  |
|-------------------------|-------------|-------------|-------------|-----------|-------------|-------------|-------------|-------------|------------------|------------------|------------------|---------------------------|------------------|
| $\overline{\mathbf{S}}$ | $\bar{I}_7$ | $\bar{I}_6$ | $\bar{I}_5$ | $ar{I}_4$ | $\bar{I}_3$ | $\bar{I}_2$ | $\bar{I}_1$ | $\bar{I}_0$ | $\overline{Y}_2$ | $\overline{Y}_1$ | $\overline{Y}_0$ | $\overline{Y}_{E\lambda}$ | $\overline{Y_S}$ |
| 1                       | ×           | ×           | ×           | ×         | ×           | ×           | ×           | ×           | 1                | 1                | 1                | 1                         | 1                |
| 0                       | 1           | 1           | 1           | 1         | 1           | 1           | 1           | 1           | 1                | 1                | 1                | 1                         | 0                |
| O                       | 0           | $\times$    | $\times$    | $\times$  | $\times$    | $\times$    | $\times$    | ×           | 0                | O                | 0                | 0                         | 1                |
| 0                       | 1           | 0           | $\times$    | $\times$  | $\times$    | $\times$    | $\times$    | $\times$    | 0                | O                | 1                | 0                         | 1                |
| 0                       | 1           | 1           | 0           | $\times$  | $\times$    | $\times$    | $\times$    | $\times$    | 0                | 1                | 0                | 0                         | 1                |
| 0                       | 1           | 1           | 1           | 0         | $\times$    | $\times$    | $\times$    | $\times$    | 0                | 1                | 1                | 0                         | 1                |
| 0                       | 1           | 1           | 1           | 1         | 0           | $\times$    | $\times$    | $\times$    | 1                | O                | 0                | 0                         | 1                |
| 0                       | 1           | 1           | 1           | 1         | 1           | 0           | $\times$    | $\times$    | 1                | 0                | 1                | 0                         | 1                |
| 0                       | 1           | 1           | 1           | 1         | 1           | 1           | 0           | ×           | 1                | 1                | 0                | 0                         | 1                |
| 0                       | 1           | 1           | 1           | 1         | 1           | 1           | 1           | 0           | 1                | 1                | 1                | 0                         | 1                |

# 编码器与译码器的实际应用



## Unit 7 组合逻辑元件

- <u>多路复用器(multiplexers)</u>
- 三态器件(Three-state Buffer)
- <u>译码器(Decoders)</u>
- 编码器(Encoders)
- 奇偶校验器
- ▶ 比较器
- 只读存储器(ROM)
- 利用MSI设计组合逻辑电路